* {
	margin: 0;
	padding: 0;
}

html,
body {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #102626;
}

.wrapper {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	-webkit-box-reflect: below 1px linear-gradient(#0001, #0004);
}

.wrapper .container {
	position: relative;
	width: 200px;
	height: 200px;
	border-radius: 50%;
	background-color: #222;
	animation: container 2s infinite linear;
}

@keyframes container {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

.wrapper .container::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 100%;
	background: linear-gradient(to top, transparent, rgba(0, 255, 249, 0.4));
	background-size: 100px 180px;
	background-repeat: no-repeat;
	border-radius: 100px 0 0 100px;
}
.wrapper .container::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 20px;
	height: 20px;
	z-index: 2;
	background: #00fff9;
	box-shadow: 0 0 10px #00fff9, 0 0 20px #00fff9, 0 0 30px #00fff9,
		0 0 40px #00fff9, 0 0 50px #00fff9, 0 0 60px #00fff9;
	border-radius: 50%;
}

.wrapper .container .cover {
	position: absolute;
	top: 20px;
	left: 20px;
	bottom: 20px;
	right: 20px;
	border-radius: 50%;
	z-index: 1;
	background-color: #102626;
}
